Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add new "address type" column to the "receiving tab" address book page #753

Draft
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

pablomartin4btc
Copy link
Contributor

@pablomartin4btc pablomartin4btc commented Sep 10, 2023

This PR fixes #646 and introduces some enhancements to the Address Book functionality.

A new "Address Type" column has been added to the address book table page, only visible for the "Receiving address" tab. Users can employ an also new added combo box at the bottom of the page to filter address by their type, this filtering can be combined with the current search line text box.
When the export feature is used, this new field will be included.

Peek 2023-09-10 19-25

As highlighted with the performed manual testing shown in the image above:

  • address type combo box has been reused from receive coins dialog, but each widget container can specify different tool-tips for their items;
  • "Sending address" tab doesn't display the new column, combo box or its label, and the search text specify only the fields to be filtered out;
  • "Receiving address" tab display the new added widgets, filter works fine in combination of either text, combo item selection or combination of both, tool-tip texts differs from the ones on the receive coins dialog where the address can be created specifying their types.

Tested in mainnet and all test networks.

For code reviewers, please check the commit messages for a detailed breakdown.

@DrahtBot
Copy link
Contributor

DrahtBot commented Sep 10, 2023

The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

Reviews

See the guideline for information on the review process.

Type Reviewers
Concept ACK hernanmarino, BrandonOdiwuor
Stale ACK MarnixCroes

If your review is incorrectly listed, please react with 👎 to this comment and the bot will ignore it on the next update.

Conflicts

No conflicts as of last run.

@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch 3 times, most recently from af3c781 to a204706 Compare September 11, 2023 23:25
Copy link
Contributor

@MarnixCroes MarnixCroes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

cACK, nice
it jumps weird when having it sorted on address type and then changing the address type.

Screencast.from.12-09-2023.10.55.01.webm

@pablomartin4btc
Copy link
Contributor Author

it jumps weird when having it sorted on address type and then changing the address type.

Yeah, it seems that that's due to the resize mode configuration, it was something that was already happening:

image

I'll check if it can be fixed.

@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch from a204706 to 4b00cdc Compare September 12, 2023 22:48
@pablomartin4btc
Copy link
Contributor Author

pablomartin4btc commented Sep 13, 2023

Fixed the issue reported by @MarnixCroes above where the columns were resizing incorrectly.

A follow up could be to set a default width value for each column or most of them and have the feature of storing the user preferable width as in the peers table in the "Node window".

image

Copy link
Contributor

@MarnixCroes MarnixCroes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The Export button works different. It doesn't open an in app dialog

master
Screenshot from 2023-09-13 14-38-15

PR
Screenshot from 2023-09-13 14-39-14

@pablomartin4btc
Copy link
Contributor Author

Thanks for checking that also @MarnixCroes.

That looks weird, the way the export button works or its functionality behind it hasn't been even touched. For me, on master and with any network passed at the startup works the same, I always get the 2nd dialog you posted.

I'll try it later on a different OS. Did the export actually worked for you? Another thing I could think of is that perhaps the new filter model has some particular behavior but I can imaging that would be used for the persistence, not for the file dialog itself, could you please try testing it just up to the 3rd. commit (that's where the new column is added but not the filter & combo-box)? On the folder you have this PR's code you can do it by running git checkout 95d5b3c65cc6be67eb270e5ddd5e8abf068fd0f3.

@MarnixCroes
Copy link
Contributor

@pablomartin4btc
Please ignore my previous comment, I cannot repro it on master or other PR commits, sorry my bad.

Did the export actually worked for you?

yes it does

Copy link
Contributor

@MarnixCroes MarnixCroes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tACK 4b00cdc

@pablomartin4btc
Copy link
Contributor Author

@pablomartin4btc Please ignore my previous comment, I cannot repro it on master or other PR commits, sorry my bad.

Don't worry, it was a good spot. This is the part of the code that opens the "Save file..." (app) dialog and as you can see the title that you were seeing in your first screenshot for master, "Export Address List" is being set there:

QString filename = GUIUtil::getSaveFileName(this,
tr("Export Address List"), QString(),
/*: Expanded name of the CSV file format.
See: https://en.wikipedia.org/wiki/Comma-separated_values. */
tr("Comma separated file") + QLatin1String(" (*.csv)"), nullptr);

That code hasn't been touched by this PR.

I couldn't reproduced it in either master or this branch in both Ubuntu 20.04 or 22.04 but I crossed compiled it in WSL and run bitcoin-qt in Windows 11 Pro and you can see the "Export Address List" dialog in both master and this PR (you can note that master doesn't have the new column address type in the receiving window):

master:
image

this PR:
image

So this PR hasn't interfered with the way that on the export feature the save file dialog is getting open or displayed.

Copy link
Contributor

@hernanmarino hernanmarino left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Concept ACK, it looks like a nice functionality. Will test after rebase

@DrahtBot DrahtBot requested a review from hernanmarino October 6, 2023 21:30
@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch from 4b00cdc to dee0b3d Compare October 7, 2023 00:43
@pablomartin4btc
Copy link
Contributor Author

Rebased.

@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch from dee0b3d to 6eb2511 Compare October 7, 2023 01:10
@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch 2 times, most recently from 4ce72d6 to dffc37f Compare October 7, 2023 01:36
Copy link
Contributor

@hernanmarino hernanmarino left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

cr ACK and tested ACK

@pablomartin4btc
Copy link
Contributor Author

@luke-jr would you be interested on looking at this if you have some time?

@luke-jr
Copy link
Member

luke-jr commented Mar 28, 2024

I don't know how useful this is. Why would users care to see only a certain type, or to see what type addresses are like this?

@pablomartin4btc
Copy link
Contributor Author

I don't know how useful this is. Why would users care to see only a certain type, or to see what type addresses are like this?

Well, since QT offers to the user the feature to create certain types, it'd make sense to list them properly identifying the original intention.

Personally, I'd add the column on the "Requested payments history" as well (or making it optional, adding previously a feature to show/ hide columns, feature that could be more useful on the Peers table).

image

It'd have been good to discuss it on the issue #646 itself, which has been moved from the core repo, perhaps I should've asked before working on it. However, given that it's already developed, I don't think it would hurt to merge it once it gets approved accordingly, of course.

Copy link
Contributor

@BrandonOdiwuor BrandonOdiwuor left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Concept ACK

Nice solution adding the AddressType column and the filter by AddressType

ui->tableView->sortByColumn(0, Qt::AscendingOrder);

// Set column widths
ui->tableView->horizontalHeader()->setSectionResizeMode(AddressTableModel::Label, QHeaderView::Stretch);
ui->tableView->horizontalHeader()->setSectionResizeMode(AddressTableModel::Label, QHeaderView::ResizeToContents);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why this change?

from this
Screenshot from 2024-04-12 16-02-55

to this
Screenshot from 2024-04-12 16-03-38

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good point, this is something that could be subject for discussion, I'm open to any suggestions. Originally, as for this change, I decided to change the resize mode from Stretch to ResizeToContents as it looked tighter to me (resize mode enum - qt doc ref). I was thinking to make a bit of a mix of both of them, Stretch for some columns and ResizeToContents to others (e.g. check here), but I see there are other devs that also calculate the size of certain columns (in the latest link they also mentioned the property setStretchLastSection, which extends the size of the last column to cover the rest of the table so there's no gap as you see in your 2nd screenshot, and I played a bit with but I finally discarded it cos there was an unexpected behaviour that can't remember now). We could also allow users resize each column as their preference and save them in the settings (I think this is done on the "Peers" table).

Please let me know your opinion on this or if you have any suggestions. Thanks!

Extract and refactor ui->addressType combo content filling into GUIUtil,
having the translated descriptions in one place and allowing other Qt widget
containers to easily create similar combo boxes with customizable tooltips
per item and default selected item, both specified by the caller.
Current OutputTypeFromDestination at outputtype, returns OUTPUT_TYPE_STRING_LEGACY
for Segwit addresses, as p2sh-segwit requires extra info from the wallet to figure
that out, this change adds a correct way to obtain the desired result from the
wallet interface. So far this will be needed from the UI to identify such type,
as currently a user could select this output type to create an address (receivecoinsdialog)
but no display of it exists.
Add new address type column to the addresstablemodel, use the getOutputType
function from the wallet interface to display the correct address type in the
new column content. Update the address book page to set the new column resize mode
and to display the new column only when the receiving tab is enabled
so it must be hidden on the sending tab.

Update AddressBookFilterProxyModel::filterAcceptsRow so the filter works also
on the new addressType column content. Also the searLineEdit greyed text
reflects that the new field/ column addressType will be included in the search/
filter by but only when the receiving tab is enabled.

Add the new column to the export feature.
@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch from d33ca3f to 16f3d54 Compare January 16, 2025 18:41
@pablomartin4btc
Copy link
Contributor Author

Rebased.

Extend AddressBookFilterProxyModel to allow using nested filters to be applied
on top of it. If future needs arise for similar filters outside the address book page,
the code could be easily refactored and moved in a new subclass of QSortFilterProxyModel,
perhaps with limits on nested levels.

For safety and performance reasons, the code of the filter proxy model class declaration
(in addressbookpage.h) and its instance creation were updated by aligning it with
TransactionFilterProxy in overviewpage.h as this addresses situations of unexpected crashes,
such as segfault on closing the app, double free or corruption, or stack smashing detection.
Introduce a label and a combobox UI widgets for address type filtering on the address book page.
These 2 widgets are been displayed only on the Receiving tab.
To ensure that the combo box selection updates the filter model correctly, an intermediary signal
(addressTypeChanged) and a slot (handleAddressTypeChanged) were necessary due to the incompatibility
between QComboBox::currentIndexChanged and QSortFilterProxyModel::setFilterFixedString.

Update filter model to use nested filtering so when selected item changes on address type combo
it will update the filter pattern on top of what the parent filter has already, which is lead by the
searchLineEdit widget and all references of the current proxyModel (eg mapToSource, mapFromSource)
to the nested and final filter model.

Use GUIUtil::AddItemsToAddressTypeCombo to populate the combo with the default output types descriptions
passing a defined local map for the output types tooltips that will be displayed for each item,
similarly to the address types combobox in receivecoinsdialog.
@pablomartin4btc pablomartin4btc force-pushed the gui-address-types-on-receiving-tab branch from 16f3d54 to cbcc625 Compare January 16, 2025 20:29
@pablomartin4btc pablomartin4btc marked this pull request as draft January 17, 2025 16:58
@pablomartin4btc
Copy link
Contributor Author

Drafted while solving the nested filter logic that immediately after rebasing clang-tidy-19 was complaining about.
[14:05:17.184] [623/666][21.4s] clang-tidy-19 -p=/ci_container_base/ci/scratch/build-x86_64-pc-linux-gnu -quiet -load=/tidy-build/libbitcoin-tidy.so /ci_container_base/src/qt/addressbookpage.cpp
[14:05:17.184] /ci_container_base/src/qt/addressbookpage.cpp:30:5: error: function 'AddressBookSortFilterProxyModel' is within a recursive call chain [misc-no-recursion,-warnings-as-errors]
[14:05:17.184]    30 |     AddressBookSortFilterProxyModel(const QString& type, QObject* parent, bool enableNestedFilter)
[14:05:17.184]       |     ^
[14:05:17.184] /ci_container_base/src/qt/addressbookpage.cpp:30:5: note: example recursive call chain, starting from function 'AddressBookSortFilterProxyModel'
[14:05:17.184] /ci_container_base/src/qt/addressbookpage.cpp:40:46: note: Frame #1: function 'AddressBookSortFilterProxyModel' calls function 'AddressBookSortFilterProxyModel' here:
[14:05:17.184]    40 |             nextedFilterProxyModel.reset(new AddressBookSortFilterProxyModel(type, this, false));
[14:05:17.186] ^^^ ⚠️ Failure generated from clang-tidy
[14:05:17.186] + echo '^^^ ⚠️ Failure generated from clang-tidy'
[14:05:17.186] + false
��������

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Organize the address types on the "Receiving addresses" tab
6 participants